

## שאלות תיאורטיות

לצורך העברת נתונים - CPU הסבר/י בפירוט את המוטיבציה לשימוש ב DMA ביחס ל tradeoff

## : תשובה

ראשית מטרת הDMA הוא העברת מידע בין רכיבי זיכרון ללא שימוש ב-CPU. המוטיבציה היא צמצום צריכת ההספק וביצוע המעבר כשהבקר במצב שינה. הtradeoff הוא שימוש בזיכרון נוסף ומספר ערוצים נמוך של הDMA המביא לסיבוכיות בפעולות הזיכרון. בנוסף לכך יש להתחשב בסינכרון של ה DMA עם שאר הרכיבים במחשב.

הסבר/י בפירוט את ארבע ה שיטות המעון, רשמו דוגמה מתאימה עבור כל אחת (2 מהשיטות.

## תשובה:

א) העתקה בודדת לכתובת בודדת – fixed address to fixed address – העתקה



בות לבלוק של כתובות fixed address to block of address (ב



Fixed Address To Block Of Addresses

ג) block of address to fixed address - העתקה מבלוק של כתובות לכתובת בודדת



ד)block of address to block of address – העתקה מבלוק של כתובות לבלוק של כתובות.



- רשמו דוגמה DMA, הסבר/י בפירוט את שש השיטות להעברת מידע בשימוש מחלים דוגמה מתאימה עבור כל אחת מהשיטות.
- א) single transfer כל מעבר דורשת טריגר ו DMEAN כל מעבר דורשת של Single transfer (א התבצעו. קינפוג : DMADTx= 000
- ב) block transfer העברת כל הבלוק מתבצעת ע"י טריגר יחיד, גם כאן DMADTx=001 מתאפס בסוף העברת הבלוק קינפוג: DMADTx=001
  - ג)Burst-Block transfer פעולות הCPU משתלבות עם העברת הבלוק. DMADTx=010 011 מתאפס בסוף העברה. קינפוג: 2011 0112 0112
    - The period (שאר DMEAN כל העברה מתבצעת ע"י טריגר, Prepeated single transfer (בשאר enabled DMADTx=100 : קנפוג: DMADTx=100 בשאר
- enabled בלוק שלם מועבר ע"י טריגר, Repeated block transfer (באר Repeated block transfer (בשאר DMADTx = 101 בנפוג
  - ו) repeated burst-block transfer פעולת ה-CPU משתלבות עם כל מעבר בלוק ו DMEAN נשאר DMEAN

קינפוג: DMADT = 110,111

DMADTx Bits DMA Transfer mode.

14-12 000 Single transfer

001 Block transfer

010 Burst-block transfer

011 Burst-block transfer

100 Repeated single transfer

101 Repeated block transfer

110 Repeated burst-block transfer

111 Repeated burst-block transfer

DAC אורך העברת מידע מהמודולים 12 DMA הסבר /י כיצד ניתן להשתמש ב DMA לצורך העברת מידע מהמודולים 12,ADC ,TimerB,

 $DAC12 \rightarrow ADC12MEMx$  $DAC12 \rightarrow DAC12\_xDAT$ 

 $TimerB \rightarrow TBCCRx$ 

בעזרת הרגיסטרים הרלוונטים בכל מודול:

ישנם 3 ערוצים לDMA ונבחר את ה SEL בהתאמה למודול הרצוי על מנת לבחור את הטריגר הרצוי להעברת המידע

0000 DMAREQ bit (software trigger)
0001 TACCR2 CCIFG bit
0010 TBCCR2 CCIFG bit
0011 URXIFG0 (MSP430FG43x), UCA0RXIFG (MPS430FG461x)
0100 UTXIFG0 (MSP430FG43x), UCA0TXIFG (MSP430FG461x)
0101 DAC12\_0CTL DAC12IFG bit
0110 ADC12\_ADC12IFGx bit

0110 ADC12 ADC12IFGx bit 0111 TACCR0 CCIFG bit 1000 TBCCR0 CCIFG bit

1001 URXIFG1 bit 1010 UTXIFG1 bit 1011 Multiplier ready

1100 No action (MSP430FG43x), UCB0RXIFG (MSP430FG461x) 1101 No action (MSP430FG43x), UCB0TXIFG (MSP430FG461x)

1110 DMA0IFG bit triggers DMA channel 1
DMA1IFG bit triggers DMA channel 2
DMA2IFG bit triggers DMA channel 0

1111 External trigger DMAE0

ומדוע יש צורך בו. Priorities Channel DMA הסבר/י את המושג

קיימים 3 ערוצים לDMA עלול להיות מצב שמופיע טריגר באחד הערוצים בעוד שערוץ אחר בעבודה, לכן יש צורך לקבוע סדר עדיפויות עבודה. ברירת המחדל היא DMA2 DMA1 DMA0 אך ניתן לשנות זאת ע"י רגיסטר ROUNDROBIN

ל) הסבירו כיצד מורכב ה Time Cycle Transfer DMA( הסבירו כיצד מורכב ה בפועל + תקורה - במקרים הבאים: במקרים הבאים: באופן כללי לDMA לוקח זמן לבצע העברת מידע, הסנכרון לוקח בין 1 ל2 מחזורי שעון

לאחר מכן העברת כתובת המכילה בתוכה בית או מילה לוקח עוד 2 מחזורי שעון.

מקרה ראשון : לפי הטבלה לוקח 4 מחזורי שעון כשהCPU עובד. מקרה שני: לוקח 5 מחזורי שעון במצב שינה

7) הסבר/י באילו תנאים תתבצע בקשת פסיקה של מודול

להשתמש בו ולאפשר אותו בתחילת כל פעם.

בשני המקרים השעון הוא MCLK.

לכל ערוץ קיים וקטור פסיקה, המקבל ערך ע"י טריגר IFG כמתואר למעלה. הטריגר עולה כאשר ה DMA מסיים את העברת המידע. צריך לאפשר פסיקות גלובליות

. ובקשת פסיקה בו זמנית. DMA הסבר/ י האם מודול פריפריאל י יכול לבצע בקשת

הוא לא יכול הוא יאלץ לחכות, הגיוני כי יכול להיות שהמידע בו הוא משתמש במהלך הפסיקה יהיה שגוי כי בזמן זה מתבצעת העברת מידע. עם זאת, פסיקות שירות של מודולי פריפריה יכולים להיחתך על ידי הDMA, לכן בכדי להתמודד עם זה נדרש לבטל את פעילות הDMA בכל פעם שנרצה להפסיק